Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Promise
- based HTTP requestorget
, post
, put
, patch
, and del
Additionally, this module is delivered as:
dist/httpie.mjs
dist/httpie.js
$ npm install --save httpie
Note: The
async
syntax is for demo purposes – you may use Promises in a Node 6.x environment too!
import { get, post } from 'httpie';
try {
const { data } = await get('https://pokeapi.co/api/v2/pokemon/1');
// Demo: Endpoint will echo what we've sent
const res = await post('https://jsonplaceholder.typicode.com/posts', {
body: {
id: data.id,
name: data.name,
number: data.order,
moves: data.moves.slice(0, 6)
}
});
console.log(res.statusCode); //=> 201
console.log(res.data); //=> { id: 1, name: 'bulbasaur', number: 1, moves: [{...}, {...}] }
} catch (err) {
console.error('Error!', err.statusCode, err.message);
console.error('~> headers:', err.headers);
console.error('~> data:', err.data);
}
Returns: Promise
Any httpie.send
request (and its aliases) will always return a Promise.
If the response's statusCode
is 400 or above, this Promise will reject with a formatted error – see Error Handling. Otherwise, the Promise will resolve with the full ClientRequest
stream.
The resolved response will receive a new data
key, which will contain the response's full payload. Should the response return JSON content, then httpie
will parse it and the res.data
value will be the resulting JSON object!
Type: String
The HTTP method name – it must be uppercase!
Type: String
or URL
If url
is a string, it is automatically parsed with url.parse()
into an object.
Type: Mixed
Default: undefined
The request's body, can be of any type!
Any non-Buffer
objects will be converted into a JSON string and the appropriate Content-Type
header will be attached.
Additionally, httpie
will always set a value for the Content-Length
header!
Type: Object
Default: {}
The custom headers to send with your request.
Type: Boolean
Default: true
Whether or not redirect responses should be followed automatically.
Note: This may only happen with a 3xx status and if the response had a
Location
header.
Type: Function
Default: undefined
An optional function that's passed directly to JSON.parse
, allowing you transform aspects of the response data before the httpie
request resolves.
Note: This will only run if
httpie
detects that JSON is contained in the response!
Alias for
send('GET', url, opts)
.
Alias for
send('POST', url, opts)
.
Alias for
send('PUT', url, opts)
.
Alias for
send('PATCH', url, opts)
.
Alias for
send('DELETE', url, opts)
.
All responses with statusCode >= 400
will result in a rejected httpie
request. When this occurs, an Error instance is formatted with complete information:
err.message
– String
– Identical to err.statusMessage
;err.statusMessage
– String
– The response's statusMessage
value;err.statusCode
– Number
– The response's statusCode
value;err.headers
– Object
– The response's headers
object;err.data
– Mixed
– The response's payload;Important: The error's
data
property may also be parsed to a JSON object, according to the response's headers.
import { get } from 'httpie';
get('https://example.com/404').catch(err => {
console.error(`(${err.statusCode}) ${err.message}`)
console.error(err.headers['content-type']);
console.error(`~> ${err.data}`);
});
//=> "(404) Not Found"
//=> "text/html; charset=UTF-8"
//=> ~> <?xml version="1.0" encoding="iso-8859-1"?>\n<!DOCTYPE html ...</body>\n</html>
MIT © Luke Edwards
FAQs
A lightweight, Promise-based wrapper for Node.js HTTP requests~!
The npm package httpie receives a total of 9,552 weekly downloads. As such, httpie popularity was classified as popular.
We found that httpie demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.